<template>
  <div>
    <el-alert
      effect="dark"
      :closable="false"
      title="由于是模拟数据，所以只提供了两种不同权限的帐号，开发者可根据实际情况自行改造结合。"
      type="info"
      style="margin-bottom: 20px"
    />

    <div class="search__example--wrap">
      <com-search :schema="searchData" @search-submit="searchSubmit" @reset-submit="resetSubmit" />
    </div>

    <com-table
      v-loading="loading"
      :columns="columns"
      :data="tableData"
      :pagination="{
        currentPage: defaultParams.pageIndex,
        total: total,
        onSizeChange: handleSizeChange,
        onCurrentChange: handleCurrentChange
      }"
    >
      <template #remark="scope">
        <span>模拟</span>
        <el-tag
          :type="scope.row.userName === 'admin' ? 'success' : 'warning'"
          style="margin: 0 15px"
        >
          {{ scope.row.userName === 'admin' ? '前端' : '后端' }}
        </el-tag>
        <span>控制路由权限</span>
      </template>
    </com-table>
  </div>
</template>

<script setup lang="ts" name="User">
import { getUserListApi } from './api'
import { useWork } from '@/hooks/work/useWork'
const {
  defaultParams,
  tableData,
  loading,
  total,
  handleSizeChange,
  handleCurrentChange,
  getList,
  searchSubmit,
  resetSubmit
} = useWork({
  listFun: getUserListApi
})

const searchData: FormSchemaConfig[] = [
  {
    label: '帐号',
    value: '',
    component: 'Input',
    field: 'userName',
    componentProps: {
      placeholder: '请输入帐号',
      clearable: true
    }
  }
]

const columns = [
  {
    field: 'userName',
    label: '帐号'
  },
  {
    field: 'password',
    label: '密码'
  },
  {
    field: 'role',
    label: '角色'
  },
  {
    label: '备注',
    field: 'remark'
  }
]

getList()
</script>
